
<template>
    <div>
        <Title :title="title"></Title>
        <!-- {{ ed }} -->
        <!-- 1.提供图标容器 ref模板引用 类似于id -->
        <div ref="left1" style="height: 150px; margin-top: 20px;"></div>
    </div>
</template>
<script>
// 引入折线图构造函数
import { line, Line } from '@antv/g2plot';
// 引入get请求
import { get } from '@/utils/request';
// 引入momentjs
import moment from 'moment';
// 引入
import { mapState } from 'vuex';
export default {
    data() {
        return {
            title: '实时温度曲线',
            params: {
                page: 1,
                pageSize: 100,
            },
            // 存放温度数据
            TempData: [],
            // 创建一个图表实例
            line:null,
        }
    },
    computed: {
        ...mapState(['ed']),
    },
    // 侦听器
    watch:{
        ed:{
            handler(n,o){
                // 根据设备信息重新查询数据 渲染图表
                this.params.engineer_id = n.engineer_id;
                this.params.device_id = n.device_id;
                this.getTempData();
                // 根据最新获取的数据重新渲染图表
                this.line.changeData(this.TempData);
            },
            // 深度侦听
            deep:true,
        }
    },
    methods: {
        // 封装加载函数折线图表函数
        loadLine() {
            // 创建折线图表实例对象
            this.line = new Line(this.$refs.left1, {
                // 将后端获取数据设置给data
                data: this.TempData,
                xField: 'insert_time',
                yField: 'temperature',
                // 配置x轴字段的对象
                xAxis: {
                    label: {
                        rotate: -45,
                        style: {
                            fill: "white",
                            fontSize: 16,
                        },
                    }
                },
                // 配置y轴字段的对象
                yAxis: {
                    label: {
                        style: {
                            fill: "white",
                            fontSize: 16,
                        },
                    }
                },
                label: {
                    style: {
                        fill: "white",
                        fontSize: 16,
                    },
                },
                point: {
                    size: 5,
                    shape: 'diamond',
                    style: {
                        fill: 'pink',
                        stroke: '#5B8FF9',
                        lineWidth: 2,
                    },
                },
                // 设置曲线是否平滑
                smooth: true,
                animation: {
                    appear: {
                        animation: 'wave-in',
                        duration: 5000,
                    },
                },
                tooltip: {
                    showMarkers: true,
                    domStyles: {
                        "g2-tooltip": {
                            background: "#147",
                            color: "white",
                            fontSize: 20,
                        },
                    },
                },
                state: {
                    active: {
                        style: {
                            shadowBlur: 4,
                            stroke: '#000',
                            fill: 'red',
                        },
                    },
                },
                interactions: [{ type: 'marker-active' }],
            });
            // 渲染折线图表
            this.line.render();
        },
        // 封装方法获取后端接口的实时数据
        async getTempData() {
            let res = await get('/dashboard/pageQueryTodayData', this.params);
            // console.log(res,"获取响应");
            let temp = [];
            res.data.list.forEach((item, index, arr) => {
                // 由于刻度混乱 将第一条数据值设置为15.4
                arr[0].temperature = 15.4;
                item.insert_time = moment(item.insert_time).format('HH:mm');
                // 由于查询数据密度密集 需要将数据处理 每隔10条数据取一条数据
                if (index % 10 == 0) {
                    temp.push(arr[index])
                }
            });
            this.TempData = temp;
        }
    },

    async mounted() {
        await this.getTempData();
        this.loadLine();
    },
}
</script>
<style lang="less" scoped></style>